新版本系统适配: Android 12 中的兼容性变更
△ 新版本系统适配: Android 12 中的兼容性变更
Bilibili 视频链接
https://www.bilibili.com/video/BV13L411c7M9/
Android 12 中的变更
兼容性变更主要分为两类,一类默认影响所有运行的应用,另一类则只基于应用已声明的目标 SDK 级别对其产生影响。方便起见,本文将在变更标题中加以备注以帮助您更好地了解对应变更内容对您应用的影响。
Android 12 采用全新的个性化 Material Design 实现了跨越式的视觉更新。我们一直致力于简化和完善现有体验并帮助您构建美观、安全和高性能的应用来满足用户需求。为此,我们专注于用户界面、性能和隐私三大方面进行优化。本文中将主要介绍 Android 12 在用户界面和性能方面的变更。
用户界面相关的变更
从 Android 12 开始,系统会在冷启动和暖启动应用时都使用新的默认开屏页。该开屏页由应用的启动图标和主题的 windowBackground 组成,并在启动时展现顺滑、流畅的过渡动画。
△ Android 12 中的默认开屏页
这种全新的体验适用于所有运行在 Android 12 上的应用。如果您的应用实现了自定义开屏页,则需要迁移到新的 SplashScreen API。我们建议使用 Jetpack 的 SplashScreen 库来实现向后兼容性,以在所有 Android 版本中提供一致的观感。
由于新开屏页可完全自定义,因此,即使您现有的开屏页用于路由,我们也建议将其完全移除。这样将避免开屏页重复,而且能减少加载时间。
如需了解详细的适配流程,请查阅 Android 开发者网站的迁移指南:
自定义通知 (仅影响 targetSdkVersion 为 31 的应用)
在之前,自定义通知能使用整个通知区域,并能提供自己的布局和样式。对于面向 Android 12 的应用,带有自定义内容视图的通知将不再使用整个通知区域,系统改而使用标准模板。
△ Android 12 之前和之后自定义通知可使用的区域对比
该模板确保自定义通知在所有状态下的装饰与其他通知相同,例如图标、应用名、展开和收起状态标识。该变更会影响使用自定义 Notification.Style 子类或使用 Notification.Builder 方法设置自定义内容视图的应用。如果您的应用正在使用完全自定义通知,请务必测试这类通知是否能够兼容新模板。
△ 受影响的自定义内容视图的 API
Android 12 还整合了现有行为,让用户在沉浸模式下更轻松地执行手势导航命令。即使处于沉浸式模式下,系统手势也会立即响应。BEHAVIOR_SHOW_BARS_BY_TOUCH 和 BEHAVIOR_SHOW_BARS_BY_SWIPE 这两种行为现已弃用,被新的 BEHAVIOR_DEFAULT 行为所取代。BEHAVIOR_DEFAULT 行为让用户只需滑动一次即可执行手势导航,而在 Android 11 上则需要滑动两次。即使是开发全屏游戏的体验,仍可在沉浸模式下通过使用 BEHAVIOR_SHOW_TRANSIENT_BARS_BY_SWIPE 标记来防止用户受到误触手势的影响。
性能相关的变更
前台服务 (仅影响 targetSdkVersion 为 31 的应用)
前台服务能让 Android 系统确保资源优先用于完成用户发起的耗时任务,但它经常被滥用。我们发现几乎一半的前台服务是从后台启动的,这导致了许多问题,包括电量会被迅速耗尽,以及用户会被意外的前台服务通知困扰等。因此从 Android 12 开始,将禁止从后台启动前台服务,并对启动前台服务作了限制。以下情况可启动前台服务:
可见的 Activity 或窗口
用户操作,如通知、小部件等等
特定的广播和回调
STICKY 类型的服务可在崩溃或由于低内存而停止运行的情况下重启
有关前台服务启动限制的完整豁免列表,请查阅 Android 开发者网站——前台服务:
今年早些时候,我们在 Jetpack 的 WorkManager 库中引入了加急任务。这些低延迟任务可从前台或后台调用并会立即执行。这些任务可在低电量模式下运行。我们鼓励开发者尽可能使用这些任务来替代启动前台服务。
在大多数情况下,应用应使用粗精确度闹钟,其优势在于省电。在闹钟和计时器等特殊情况下,可使用精确闹钟。Android 12 新增了一项清单权限——SCHEDULE_EXACT_ALARM,用户可查看并控制拥有此权限的应用。此外,还新增了一个新的 API —— canScheduleExactAlarms(),您可使用此 API 来检查应用的权限状态。
一些应用在处理用户点击通知的行为时,会使用广播接收器或服务等中间组件,这些组件被称为通知 trampoline,它们常常导致延迟和用户流程中断,面向 Android 12 的应用将不能从这些蹦床启动 Activity。这一新限制有助于减少从通知启动应用的延迟。我们鼓励弃用通知 trampoline 并直接从通知启动目标 Activity。举个例子,在弃用通知 trampoline 后,Google 相册应用的启动速度提高了 34%。如果您的应用使用了通知 trampoline,请使用以下 adb 命令查看用户与通知交互时所启动的组件:
$ adb shell dumpsys activity service \
com.android.systemui/.dump.SystemUIAuxiliaryDumpService
Android 支持应用链接的概念,它可以让 HTTP 网址直接链接到已安装的应用。这样便可完全绕过消歧对话框,通过消除用户使用过程中的分歧来改善用户体验。应用链接与深层链接的区别在于应用链接只能处理 HTTP 模式,而深层链接可以处理任何模式。
不同于以前的版本,Android 12 将始终为未验证的链接打开默认浏览器。这可能是应用链接在行为方面最重要的变更。Android 12 还引入了逐条链接验证,因此,如果存在任何服务器端集成或配置错误,将仅限于未通过验证的链接,您可以使用新 DomainVerificationManager API 检查域名验证状态,并在需要时将用户带到「设置」以便批准应用使用的域名。如需了解详情,请参阅 Android 开发者网站——验证 Android 应用链接:
△ 使用应用链接绕过消歧对话框直达已安装应用
兼容性框架工具
D CompatibilityChangeReporter: Compat change id reported: 170668199 ;
UID 10265; state: ENABLED
您可以使用以下 adb 命令列出系统已知的所有兼容性变更 (包括已启用和禁用的变更) 及其当前的启用情况。列表中的每项变更都有名称、供引用的变更 ID 和启用/禁用状态。
$ adb shell dumpsys platform-compat
还可以使用以下 adb 命令打开或关闭某个软件包的变更:
$ adb shell am compat enable|disable|reset <CHANGE_ID | CHANGE_NAME> <PACKAGE_NAME>
△ 使用 adb 命令设置单个应用的变更
<application
android:debuggable="true">
△ 在清单文件中将应用设置为可调试
请记住在已签名的 Android 发布版本上,无法修改影响所有应用的变更的启用状态。Android 12 添加了新的 adb 命令来测试和验证应用的应用链接。您可使用这些命令在设备上手动验证链接,或将其添加到持续集成工具链中。
// 清除应用任何已经验证的状态:
$ adb shell pm set-app-links --package PACKAGE_NAME 0 all
// 开始验证测试:
$ adb shell pm verify-app-links --re-verify PACKAGE_NAME
// 查看测试结果:
$ adb shell pm get-app-links PACKAGE_NAME
开发者案例
附近设备权限 (仅影响 targetSdkVersion 为 31 的应用)
△ HealthMate 应用申请附近设备权限
对我们而言,附近设备权限是 Android 12 中最重要的变更之一。 Withings HealthMate
将检查和申请新权限的逻辑进行抽象。这有助于控制入口点并尽可能减少测试工作; 在所有受支持的 Android 版本上对所有权限检查进行单元测试; 使用 Android 真机并测试不同的升级场景以确保应用正常运行; 如果应用在之前的 Android 版本上获得了位置权限,当用户升级到 Android 12 时,该应用将自动被授予附近设备权限。
要使用新的附近设备权限,必须在清单文件中声明 BLUETOOTH_SCAN 权限:
<uses-permission
android:name="android.permission.BLUETOOTH_SCAN"
android:usesPermissionFlags="neverForLocation" />
△ 扫描附近设备时应在清单文件中声明权限
<uses-permission
android:name="android.permission.BLUETOOTH_CONNECT" />
过度滚动效果 (Overscroll Effect,影响所有应用)
我们为 Android 12 正式版及时修复了过度滚动的问题并为用户提供了统一的体验。 Signal Private Messenger
注意混合模式及其作为附加层的工作原理。Android 12 过度滚动使用附加层来渲染拉伸效果,这可通过不同混合算法生成不同的结果; 确保背景由 RecyclerView 渲染; 在发布之前,执行一次全面质量检查,并解决用户对 Android 12 兼容性的反馈。
Signal 应用是提供愉悦用户体验的一个范例。幸运的是,Android 版 Signal Private Messenger 为开源软件,您可在 GitHub 上查看其修复代码:
总结
在本文中,我们介绍了 Android 12 给开发者及用户带来的最重要的几项变更,并提出部分建议:
Android 12 带来了明显的视觉更新 使用已提供的工具和建议来测试您的应用
从其他开发者处获得启发
更多变更相关内容,请参阅 Android 开发者网站——Android 12:
https://developer.android.google.cn/about/versions/12
推荐阅读